<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>定时器引发的思考</title>
</head>
<body>

<button id="btn">启动定时器</button>

<!-- 
    1. 定时器真是定时执行的吗？
        - 定时器并不能保证真正定时执行
        - 一般会延迟一丁点（可以接受），也有可能延迟很长时间（不能接受）
    2. 定时器回调函数是在分线程执行的吗？
        - 在主线程执行的，js 是单线程的
    3. 定时器是如何实现的？
        - 事件循环模型（后面讲）
 -->

<script type="text/javascript">
    document.getElementById('btn').onclick = function(){
        var start = Date.now()
        console.log('启动定时器前...')
        setTimeout(function(){
            console.log('定时器执行',Date.now()-start)
        }, 200)
    
    
        for (var i = 0; i < 1000000000; i++) {
            
        }
    }
</script>
</body>
</html>